阅读更多

Excel和Word 简易工具类,JEasyPoi 2.1.5 版本发布 

摘要:

     jeasypoi 功能如同名字easy,主打的功能就是容易,让一个没见接触过poi的人员 就可以方便的写出Excel导出,Excel模板导出,Excel导入,Word模板导出,通过简单的注解和模板 语言(熟悉的表达式语法),完成以前复杂的写法。

    主要特点:
          1.设计精巧,使用简单
          2.接口丰富,扩展简单
          3.默认值多,write less do more
          4.AbstractView 支持,web导出可以简单明了

 

一、升级日志

Excel和Word简易工具类,可以无缝集成springmvc,也为jeecg快速开发平台提供更便捷的,强大的导入导出。
  • 一对多表结构导入导出BUG修正;
  • jeecg 个性化定制版;
  • 支持配置jeecg字典code 翻译导出;
  • 支持自定义字典扩展接口,方便用户自定义;
  • 大数据导入导出优化;

二、在线WIKI文档

        这几篇是旧的教程,不过和现在大同小异

               Excel 介绍篇 Excel 工具类 Excel 注解介绍.第一篇 Excel 注解介绍.第二篇 Excel 实体类 Word模板导出教程

        后面都是新的了

               JEasyPoi 在spring mvc中简易开发方式

               JEasyPoi-新版自定义导出样式类型

               JEasyPoi-标签-模板导出的语法介           

               JEasyPoi-Excel预览

三、JEasyPoi 集成方法

           1.   采用 maven方式

                  在pom.xml 引入以下依赖。配置私服http://maven.jeecg.org/nexus/

                <dependency>
			<groupId>org.jeecgframework</groupId>
			<artifactId>jeasypoi-base</artifactId>
			<version>2.1.5</version>
		</dependency>
		<dependency>
			<groupId>org.jeecgframework</groupId>
			<artifactId>jeasypoi-web</artifactId>
			<version>2.1.5</version>
		</dependency>
		<dependency>
			<groupId>org.jeecgframework</groupId>
			<artifactId>jeasypoi-annotation</artifactId>
			<version>2.1.5</version>
		</dependency>

 

2. 非maven方式

  直接拷贝相关jar进项目Lib中

 

四、源码下载

                http://git.oschina.net/jeecg/jeasypoi

                https://github.com/zhangdaiscott/jeasypoi

五、技术交流

六、测试实战

1.注解,导入导出都是基于注解的,实体上做上注解,标示导出对象,同时可以做一些操作

	@ExcelTarget("courseEntity")
	public class CourseEntity implements java.io.Serializable {
	/** 主键 */
	private String id;
	/** 课程名称 */
	@Excel(name = "课程名称", orderNum = "1", needMerge = true)
	private String name;
	/** 老师主键 */
	@ExcelEntity(id = "yuwen")
	@ExcelVerify()
	private TeacherEntity teacher;
	/** 老师主键 */
	@ExcelEntity(id = "shuxue")
	private TeacherEntity shuxueteacher;

	@ExcelCollection(name = "选课学生", orderNum = "4")
	private List<StudentEntity> students;

2.基础导出 传入导出参数,导出对象,以及对象列表即可完成导出

	HSSFWorkbook workbook = ExcelExportUtil.exportExcel(new ExportParams(
				"2412312", "测试", "测试"), CourseEntity.class, list);

3.基础导出,带有索引 在到处参数设置一个值,就可以在导出列增加索引

	ExportParams params = new ExportParams("2412312", "测试", "测试");
	params.setAddIndex(true);
	HSSFWorkbook workbook = ExcelExportUtil.exportExcel(params,
			TeacherEntity.class, telist);

4.导出Map 创建类似注解的集合,即可完成Map的导出,略有麻烦

	List<ExcelExportEntity> entity = new ArrayList<ExcelExportEntity>();
	entity.add(new ExcelExportEntity("姓名", "name"));
	entity.add(new ExcelExportEntity("性别", "sex"));

	List<Map<String, String>> list = new ArrayList<Map<String, String>>();
	Map<String, String> map;
	for (int i = 0; i < 10; i++) {
		map = new HashMap<String, String>();
		map.put("name", "1" + i);
		map.put("sex", "2" + i);
		list.add(map);
	}

	HSSFWorkbook workbook = ExcelExportUtil.exportExcel(new ExportParams(
			"测试", "测试"), entity, list);	

5.模板导出 根据模板配置,完成对应导出

	TemplateExportParams params = new TemplateExportParams();
	params.setHeadingRows(2);
	params.setHeadingStartRow(2);
	Map<String,Object> map = new HashMap<String, Object>();
    map.put("year", "2013");
    map.put("sunCourses", list.size());
    Map<String,Object> obj = new HashMap<String, Object>();
    map.put("obj", obj);
    obj.put("name", list.size());
	params.setTemplateUrl("org/jeecgframework/poi/excel/doc/exportTemp.xls");
	Workbook book = ExcelExportUtil.exportExcel(params, CourseEntity.class, list,
			map);

6.导入 设置导入参数,传入文件或者流,即可获得相应的list

	ImportParams params = new ImportParams();
	params.setTitleRows(2);
	params.setHeadRows(2);
	//params.setSheetNum(9);
	params.setNeedSave(true);
	long start = new Date().getTime();
	List<CourseEntity> list = ExcelImportUtil.importExcel(new File(
			"d:/tt.xls"), CourseEntity.class, params);

7.和spring mvc的无缝融合 简单几句话,Excel导出搞定

	@RequestMapping(params = "exportXls")
	public String exportXls(CourseEntity course,HttpServletRequest request,HttpServletResponse response
			, DataGrid dataGrid,ModelMap map) {

        CriteriaQuery cq = new CriteriaQuery(CourseEntity.class, dataGrid);
        org.jeecgframework.core.extend.hqlsearch.HqlGenerateUtil.installHql(cq, course, request.getParameterMap());
        List<CourseEntity> courses = this.courseService.getListByCriteriaQuery(cq,false);

        map.put(NormalExcelConstants.FILE_NAME,"用户信息");
        map.put(NormalExcelConstants.CLASS,CourseEntity.class);
        map.put(NormalExcelConstants.PARAMS,new ExportParams("课程列表", "导出人:Jeecg",
                "导出信息"));
        map.put(NormalExcelConstants.DATA_LIST,courses);
        return NormalExcelConstants.JEECG_EXCEL_VIEW;

	}

8.Excel导入校验,过滤不符合规则的数据,追加错误信息到Excel,提供常用的校验规则,已经通用的校验接口

	/**
     * Email校验
     */
    @Excel(name = "Email", width = 25)
    @ExcelVerify(isEmail = true, notNull = true)
    private String email;
    /**
     * 手机号校验
     */
    @Excel(name = "Mobile", width = 20)
    @ExcelVerify(isMobile = true, notNull = true)
    private String mobile;
    
    ExcelImportResult<ExcelVerifyEntity> result = ExcelImportUtil.importExcelVerify(new File(
            "d:/tt.xls"), ExcelVerifyEntity.class, params);
    for (int i = 0; i < result.getList().size(); i++) {
        System.out.println(ReflectionToStringBuilder.toString(result.getList().get(i)));
    }

9.导入Map 设置导入参数,传入文件或者流,即可获得相应的list,自定义Key,需要实现IExcelDataHandler接口

	ImportParams params = new ImportParams();
	List<Map<String,Object>> list = ExcelImportUtil.importExcel(new File(
			"d:/tt.xls"), Map.class, params);
0
0
评论 共 0 条 请登录后发表评论

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • socket 实现进程间通信

    实现三个进程用socket完成进程间通信。用到socket 的本地通信,与select()函数,信号,还有在一个进程中完成另外一个进程的重新启动

  • 进程间通信之:socket

    最近初步学习了本地进程间通信的方式(PIPE、FIFO、message queue、semaphore、shared memary),计划按照“unix 环境高级编程”来学习socket,但是书本上来就讲socket的一些api,感觉一直没搞懂,通过今天的网络搜索,终于发现几篇不错的文章,再次整理一下,即梳理思路,又可转换成自己容易理解的语言。1.TCP/IP  在学习socket之前,先简单了解一

  • JAVA使用Socket进行异步通讯

    本文章除了基本的socket知识以外,还用到了包括死循环获取用户连接请求,异步多线程的消息读取和写入等知识,博主前后在踩坑上花的时间至少都有10个小时,希望能帮助到你 从第一次接触socket到现在已经经过了小半年的时间,当时老师只是提了一下socket通讯是长连接,一个socket可以互相发送多次消息,但是具体实现大家都没有做出来,复制了网上的代码进行实现也不知道原理是什么,今天终于又花了将近

  • socket阻塞与非阻塞,同步与异步、I/O模型

    socket阻塞与非阻塞,同步与异步 作者:huangguisu 1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步: 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。也就是必须一件一件事做,等前一...

  • 华为出品免费安卓测速工具 一键测速 2.1.5 中文免费版.zip

    华为一键测速,是一款集成移动网络和WIFI网络上传、下载以及诊断功能的专业测试工具。 具备安装简单、使用方便、结果准确等特点。 可支持运营商 2G/3G/4G/5G 网络,以及 WIFI 网络测速以及时延抖动测试及诊断,可...

  • 电信数智商用密码数字证书合格检测工具2.1.5版

    SM2数字证书,充分借鉴与吸收了X509数字证书的格式与优点,在考虑RSA算法的优缺点之后,推出的基于商密公钥算法的SM2证书规范,至此,商密算法的数字证书在商用密码应用安全性评估...都可以通过该工具进行合规性检测。

  • nginx网页配置工具 v2.1.5

    为您提供nginx网页配置工具下载,nginx网页配置工具是一款可以使用网页来快速配置与管理nginx集群的nginx辅助工具。nginx网页配置工具功能:1、本项目可以使用WebUI配置nginx的各项功能,包括http协议转发,tcp协议...

  • WORD2CHM Assistant 2.1.5 破解教程

    WORD2CHM Assistant CHM制作助手 2.1.5 破解教程

  • screenrecorder_2.1.5录屏工具

    Apowersoft 录屏王是一款简便易用的windows桌面屏幕录制工具,能够清晰地录制电脑桌面活动,并在录制过程中实现画面与声音同步。录制完成后,视频自动保存为WMV格式。同时,通过软件内置的格式转换器,视频还可转换...

  • TbsZipZip处理类v2.1.5.zip

    TbsZipZip处理类v2.1.5.zip

  • 根据文件模板实现预览、生成word、pdf、excel(后端-项目)

    根据模板生成word、pdf、excel文件的后端项目。提供项目下载路径及解释文档,下载基本就可以用了。复制一下到项目中就能用上

  • vlcwin_15_vs2010 VLC 2.1.5版本的开发源码-win

    VLC 2.1.5版本的开发源码 win版本 流媒体 vlcwin_15_vs2010

  • 完整安装GNS3(关联GNS3 VM) 2.1.5版本

    GNS3是思科的一款模拟器,支持路由器,防火墙,二、三层交换机设备。...由于发现网上关于GNS3的教程还有资料停留在气球版(老版本),已经不适应现在的新东西了。所以写此给大家。关于现在最新版gns3是2.1.5

  • 【Python】 Python3读写Excel - 4种方式(读这一篇就够了)

    Python3读写Excel文件 1、Python中几种常用包比较 2、用xlrd包读取Excel文件 2.1、用法 2.1.1、引用包 2.1.2、打开文件 2.1.3、获取你要打开的sheet文件 2.1.4、获取指定单元格里面的值 2.1.5、获取某行或者某列的值...

  • 网站页面域名获取工具-Edge (2.1.5P)

    用Python写了一个小工具,可以打开指定网站,抓取此网站的所有域名。 适合用来做分流和过滤。

  • Keras-2.1.5.tar.gz

    该资源为Keras-2.1.5.tar.gz,欢迎下载使用哦!

  • 数据库打开工具sqlitestudio-2.1.5

    数据库打开工具sqlitestudio-2.1.5 https://blog.csdn.net/qq_31939617/article/details/80341928

  • Icon Tool(免费图标工具) v2.1.5.zip

    使用“免费图标工具”可以提取EXE、DLL、OCX、CPL、CIL文件中的图标或者打开各种图片文件,并把这些提取的图标及图片保存为图标文件或者是其他格式的图片文件。 界面简单实用,用户操作方便。 Icon Tool截图:

Global site tag (gtag.js) - Google Analytics